// C++ informative line for the emacs editor: -*- C++ -*-
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 * Copyright by The HDF Group.                                               *
 * Copyright by the Board of Trustees of the University of Illinois.         *
 * All rights reserved.                                                      *
 *                                                                           *
 * This file is part of HDF5.  The full HDF5 copyright notice, including     *
 * terms governing use, modification, and redistribution, is contained in    *
 * the COPYING file, which can be found at the root of the source code       *
 * distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases.  *
 * If you do not have access to either file, you may request a copy from     *
 * help@hdfgroup.org.                                                        *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */

#ifndef __H5DataSpace_H
#define __H5DataSpace_H

namespace H5 {

/*! \class DataSpace
    \brief Class DataSpace inherits from IdComponent and provides wrappers for
     the HDF5's dataspaces.
*/
//  Inheritance: IdComponent
class H5_DLLCPP DataSpace : public IdComponent {
   public:
        ///\brief Default DataSpace objects
        static const DataSpace& ALL;

        // Creates a dataspace object given the space type
        DataSpace(H5S_class_t type = H5S_SCALAR);

        // Creates a simple dataspace
        DataSpace(int rank, const hsize_t * dims, const hsize_t * maxdims = NULL);

        // Creates a DataSpace object using an existing dataspace id.
        DataSpace(const hid_t space_id);

        // Copy constructor - same as the original DataSpace.
        DataSpace(const DataSpace& original);

        // Assignment operator
        DataSpace& operator=(const DataSpace& rhs);

        // Closes this dataspace.
        virtual void close();

        // Makes copy of an existing dataspace.
        void copy(const DataSpace& like_space);

        // Copies the extent of this dataspace.
        void extentCopy(const DataSpace& dest_space) const;
        // removed from 1.8.18 and 1.10.1
        //void extentCopy(DataSpace& dest_space) const;

        // Gets the bounding box containing the current selection.
        void getSelectBounds(hsize_t* start, hsize_t* end) const;

        // Gets the number of element points in the current selection.
        hssize_t getSelectElemNpoints() const;

        // Retrieves the list of element points currently selected.
        void getSelectElemPointlist(hsize_t startpoint, hsize_t numpoints, hsize_t *buf) const;

        // Gets the list of hyperslab blocks currently selected.
        void getSelectHyperBlocklist(hsize_t startblock, hsize_t numblocks, hsize_t *buf) const;

        // Get number of hyperslab blocks.
        hssize_t getSelectHyperNblocks() const;

        // Gets the number of elements in this dataspace selection.
        hssize_t getSelectNpoints() const;

        // Retrieves dataspace dimension size and maximum size.
        int getSimpleExtentDims(hsize_t *dims, hsize_t *maxdims = NULL) const;

        // Gets the dimensionality of this dataspace.
        int getSimpleExtentNdims() const;

        // Gets the number of elements in this dataspace.
        // 12/05/00 - changed return type to hssize_t from hsize_t - C API
        hssize_t getSimpleExtentNpoints() const;

        // Gets the current class of this dataspace.
        H5S_class_t getSimpleExtentType() const;

        // Determines if this dataspace is a simple one.
        bool isSimple() const;

        // Sets the offset of this simple dataspace.
        void offsetSimple(const hssize_t* offset) const;

        // Selects the entire dataspace.
        void selectAll() const;

        // Selects array elements to be included in the selection for
        // this dataspace.
        void selectElements(H5S_seloper_t op, const size_t num_elements, const hsize_t *coord) const;

        // Selects a hyperslab region to add to the current selected region.
        void selectHyperslab(H5S_seloper_t op, const hsize_t *count, const hsize_t *start, const hsize_t *stride = NULL, const hsize_t *block = NULL) const;

        // Resets the selection region to include no elements.
        void selectNone() const;

        // Verifies that the selection is within the extent of the dataspace.
        bool selectValid() const;

        // Removes the extent from this dataspace.
        void setExtentNone() const;

        // Sets or resets the size of this dataspace.
        void setExtentSimple(int rank, const hsize_t *current_size, const hsize_t *maximum_size = NULL) const;

        ///\brief Returns this class name.
        virtual H5std_string fromClass () const { return("DataSpace"); }

        // Gets the dataspace id.
        virtual hid_t getId() const;

        // Deletes the global constant
        static void deleteConstants();

        // Destructor: properly terminates access to this dataspace.
        virtual ~DataSpace();

#ifndef DOXYGEN_SHOULD_SKIP_THIS

   protected:
        // Sets the dataspace id.
        virtual void p_setId(const hid_t new_id);

#endif // DOXYGEN_SHOULD_SKIP_THIS

   private:
        hid_t id;       // HDF5 dataspace id

#ifndef DOXYGEN_SHOULD_SKIP_THIS

        static DataSpace* ALL_;

        // Creates the global constant
        static DataSpace* getConstant();

        // Friend function to set DataSpace id.  For library use only.
        friend void f_DataSpace_setId(DataSpace *dspace, hid_t new_id);

#endif // DOXYGEN_SHOULD_SKIP_THIS

}; // end of DataSpace
} // namespace H5

#endif // __H5DataSpace_H
